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SYSTEM AND METHOD FOR PERFORMING A BUSINESS PROCESS 
IN A MULTI-ENTERPRISE, COLLABORATING NETWORK 

TECHNICAL FIELD OF THE INVENTION 

This invention relates in general to da 
5 communication, and more particularly to a system f 

performing a business process using a business applicati 
in a multi-enterprise, collaborating network. 
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RACKGROUNP OF THE INVENTION 

Businesses rely on the electronic communication of 
information using communication links to perform business 
processes. In the past, for example, businesses have used 
Electronic Data Interchange (EDI) networks to buy, sell, 
and trade information and goods. EDI defines a set of 
business processes performed by software interfaces, 
translators, and mapping protocols that must adhere to 
strictly-defined EDI standards to communicate a business 
document from one business to another. Several national 
and international organizations oversee, maintain, and 
enhance these EDI standards. 

The rate of change of business processes, however, is 
increasing due to such technology innovations as the 
15 Internet. The EDI solution to this problem has been to 

create multiple versions of its standards. Therefore, 
there is no one true standard for performing particular 
business processes, but rather a set of different standard 
versions. EDI defines no mechanism for how these multiple 
20 versions should interoperate . 

One solution to this problem is the development of an 
entire industry directed to translating between the 
different versions of EDI. Translation is a particularly 
integral part of EDI operation. Translators describe the 
25 relationship between the data elements in the underlying 

business application and the EDI standards (ANSI X12, 
EDIFACT, and others) by interpreting the information and 
putting it into a standard EDI document format. A drawback 
to this approach is that each business must maintain a 
30 mapping from its internal system to the EDI standard with 

which it is sending and/or receiving messages from another 
business. Whenever a business upgrades to a new version of 
an EDI standard for performing particular business 
processes, all of its business partners are immediately 
35 affected and must immediately upgrade their translators. 

Therefore prior systems are not stable or scalable. 
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SUMMARY OF THE INVENTION 

In accordance with the present invention, the 
disadvantages and problems associated with prior systems 
for performing business processes have been substantially 
reduced or eliminated. 

In accordance with one embodiment of the present 
invention, a system for performing a business process 
includes a first version of a business application that is 
identified using a first version identifier and executed by 
a first client to perform a particular business process. 
A second version of the business application that is 
identified using a second version identifier and executed 
by a second client to perform the business process, wherein 
the second client is coupled to the first client using a 
communication link. The second version of the business 
application determines a selected one of the first version 
of the business application and the second version of the 
business application to initiate the business process based 
upon the first version identifier and the second version 
identifier. 

Another embodiment of the present invention is a 
method for performing a business process that includes 
determining a first version identifier associated with a 
first version of a business application used by a first 
client to perform a business process. The method continues 
by determining a second version identifier associated with 
a second version of the business application used by a 
second client to perform the business process. The method 
concludes by determining a selected one of the first 
version of the business application and the second version 
of the business application to initiate the business 
process based upon the first version identifier and the 
second version identifier. 

Technical advantages of the present invention include 
a business application that executes to perform a 
particular business process and that may be categorized 
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using versions of varying degrees. Some versions of the 
business application are generally referred to as more 
robust, more advanced, or otherwise higher than other 
versions of the business application if they provide 
5 enhanced functionality or services in performing the 

associated business process. A particular advantage of the 
present invention is that higher level versions of a 
business application exhibit "backward compatibility" that 
allows them to understand, meaningfully interact with, or 

10 otherwise support lower level versions of the business 

application. For example, higher level versions of a 
business application can operate using files, message 
formats, protocols, data structures, commands, and other 
functionality associated with lower level versions of the 

15 business application. Therefore, higher level versions of 

a business application may exhibit backward compatibility 
by performing an associated business process according to 
the functionality of the lower level versions of the 
business application. A further technical advantage 

20 provided by the present invention is that the business 

applications exhibit "bidirectional executability" such 
that a particular business application may execute a 
business process that, from a business standpoint, it does 
not initiate itself. 

25 Still further technical advantages of the present 

invention include a system for performing a business 
process in which a first client executes a first version of 
the business application to perform a business process and 
a second client coupled to the first client executes a 

3 0 second version of the business application to perform the 

business process. The client operating the higher level 
version of the business application is selected to execute 
the business process. By exhibiting backward compatibility 
and/or bidirectional executability the selected version of 

35 the business application performs the business process in 

a manner supported by the lower level version of the 
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business application maintained by its partner client. In 
this respect, the business process is executed between 
clients maintaining different versions of the business 
application. 

Another advantage provided by the present invention is 
that because the business applications exhibit 
bidirectional executability and backward compatibility, a 
particular client can upgrade the version of a particular 
business application without negatively impacting any other 
client in the system. As a result, the system is not in a 
constant state of change so that the system is stable with 
respect to time. Furthermore, the system can support many 
clients so that it is scalable in terms of size. 

Other technical advantages are readily apparent to one 
skilled in the art from the following figures, descriptions 
and claims. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

For a more complete understanding of the present 
invention and its advantages, reference is now made to the 
following description taken in conjunction with the 
accompanying drawings, in which like reference numbers 
indicate like features and wherein: 

FIGURE 1 illustrates a system for performing a 
business process according to the present invention; 

FIGURE 2 illustrates one embodiment of a business 
application of the system; 

FIGURES 3A and 3B illustrate exemplary communications 
between different clients of the system to perform a 
business process according to the present invention; and 

FIGURE 4 is a flowchart of an exemplary method for 
performing a business process according to the present 
invention . 
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DETAILED DESCRIPTION OF THE INVENTION 

FIGURE 1 illustrates a system 10 for performing a 
business process that includes clients 12a-12e, generally 
referred to as clients 12, coupled to each other using 
communication links 14. Clients 12 perform particular 
business processes with each other using corresponding 
business applications 16 that may be categorized according 
to varying degrees of versions 18, In general, higher 
level versions 18 of business applications 16 may 
understand, meaningfully interact with, or otherwise 
support lower level versions 18 of business applications 
16. In this respect, a higher level version 18 of a 
business application 16 can perform the associated business 
process according to the functionality of any lower level 
version 18 of the business application 16. Therefore, a 
first client 12 seeking to perform a particular business 
process with a second client 12 using a business 
application 16 determines which client 12 executes the 
particular business process using the higher level version 
18 of the business application 16. The determined client 
12 then performs the business process in a manner supported 
by the lower level version 18 of the business application 
16 . 

Clients 12 comprise computers, workstations, or any 
other suitable combination of processing and memory devices 
that include the appropriate hardware and software 
capabilities to execute business applications 16. Clients 
12 communicate with each other using hardware and software 
associated with links 14. For example, clients 12 couple 
to each other using communication devices that may include 
any combination of hubs, routers, bridges, gateways, 
firewalls, switches, remote access devices, or any other 
association of suitable communication devices and related 
software that facilitate communication among clients 12 
using links 14. Although FIGURE 1 illustrates clients 12a- 
12e, it should be understood that system 10 may include any 
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number and combination of clients 12. Clients 12 perform 
particular business processes with other clients 12, 
generally referred to as partner clients 12, using the 
appropriate business applications 16 . 

A business process comprises any transaction between 
clients 12 that involves the exchange of information using 
a business application 16. Although the following 
description of system 10 is detailed with reference to a 
particular type of business process, such as an "Order 
Purchasing" business process, it should be understood that 
system 10 supports any appropriate type of business process 
in any suitable business industry. For example, system 10 
supports business processes in the consumer goods 
manufacturing industry (e.g., order purchasing, accounting, 
procurement, shipping, delivery, replenishment, inventory 
management, marketing automation, and supply chain 
integration); the distribution industry (e.g., tracking, 
shipping, and routing) ; the financial services industry 
(e.g., electronic funds transfer, electronic payment 
systems, security systems) ; and any suitable type of 
business process in any other business industiry. 

Each link 14 may be a dedicated or switched link over 
the public switched telephone network (PSTN) , a satellite 
link, a microwave link, or any other appropriate 
communication link between clients 12 . The components of 
system 10 may be part of a local area network (LAN) , a wide 
area network (WAN) , a virtual private network (VPN) , or any 
other suitable arrangement of interconnected computing 
devices that form a multi-enterprise, collaborating 
network. In a particular embodiment, clients 12 in system 
10 communicate over the Internet using the worldwide web 
(WWW) , file transfer protocol (FTP) , or any other 
communication technique. For example, clients 12 may 
maintain and execute a browser or other suitable program 
for accessing and communicating information addressed by a 
uniform resource locator (URL) using links 14. 
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Each business application 16 comprises a software 
computer program written in any suitable computer language 
that may be compiled based on the instructions of a 
selected computer operating system associated with a 
5 corresponding client 12. Business applications 16 are 

described in greater detail with reference to FIGURE 2. In 
general, each business application 16 executes to perform 
a particular business process and may be categorized using 
versions 18. Some versions 18 of a particular business 

10 application 16 are generally referred to as more robust, 

more advanced, or otherwise higher than other versions 18 
of the business application 16 if they provide enhanced 
functionality or services in performing the associated 
business process. The particular versions 18 of a business 

15 application 16 may be indicated using version identifiers. 

A particular advantage of system 10 is that higher 
level versions 18 of a business application 16 exhibit 
"backward compatibility" that allows them to understand, 
meaningfully interact with, or otherwise support lower 

20 level versions 18 of the business application 16. For 

example, higher level versions 18 of a business application 
16 can operate using files, message formats, protocols, 
data structures, commands, and other functionality 
associated with lower level version 18 of business 

25 application 16. Therefore, higher level versions 18 of a 

business application 16 may exhibit backward compatibility 
by performing an associated business process according to 
the functionality of the lower level versions 18 of the 
business application 16. Although business applications 16 

3 0 support backward compatibility, it should be understood 

that whether a particular version 18 of a business 
application 16 actually executes backward compatibility is 
based in part upon, for example , the versions 18 of the 
business application 16 maintained by its partner clients. 

35 Clients 12 of system 10 may perform different 

activities depending upon the particular business process 
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to be executed. For example, during the execution of a 
order purchasing business process, respective clients 12 
may perform buyer and/or seller activities, and are 
therefore generally referred to as buyer clients 12 and 
5 seller clients 12 . A further technical advantage provided 

by system 10 is that business applications 16 exhibit 
"bidirectional executability " such that a particular 
business application 16 may execute a business process 
that, from a business standpoint, it does not initiate 

10 itself. For example, a portion of the order purchasing 

business process may involve a buyer client 12 
communicating a purchase order to a seller client 12. From 
a business standpoint, this business process is initiated 
by the buyer client 12, so that the buyer client 12 may be 

15 referred to as a "business initiator." However, the higher 

level version 18 of business application 16 may execute the 
order purchasing business process even if it is maintained 
by a seller client 12 rather than by the buyer client 12 
that is the business initiator. Although business 

20 applications 16 support bidirectional executability, it 

should be understood that whether a particular version 18 
of business application 16 exhibits bidirectional 
executability is based in part upon, for example, whether 
the client 12 maintaining the business application 16 is 

25 the business initiator for the particular business process. 

In operation, clients 12 execute business applications 
16 to perform one or more business processes in system 10 . 
Although the following description of FIGURE 1 is detailed 
with respect to a first client 12 and a second client 12, 

3 0 it should be understood that the business processes may be 

executed by any appropriate number and combination of 
clients 12 in system 10. A first client 12, such as a 
business initiator seeking to perform a particular business 
process with a second client 12, determines which client 12 

3 5 maintains a higher level version 18 of the appropriate 

business application 16 used to execute the business 
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process. In one embodiment, the first client 12 

communicates a request to identify the version 18 of the 
business application 16 maintained by the second client 12. 
In another embodiment, the first client 12 stores 
5 information identifying the version 18 of the appropriate 

business application 16 maintained by each of its partner 
clients 12, such as the second client 12, to perform the 
particular business process. This information may be 
validated by each partner client 12 for a predetermined 

10 duration of time during which the version 18 of the 

business application 16 will not change. 

The client 12 having the higher level version 18 of 
the appropriate business application 16 exhibits "backward 
compatibility" and/or "bidirectional executability" to 

15 execute the particular business process with the other 

client 12. In particular, the client 12 having the higher 
level version 18 of the business application 16 performs 
the particular business process in a manner supported by 
the lower level version 18 of the business application 16 

20 maintained by its partner client 12. In this respect, the 

business process is executed between clients 12 maintaining 
different versions 18 of the business application 16. 

A problem with prior systems using EDI, for example, 
is that businesses employing different versions of EDI 

25 standards to perform a business process must maintain a 

mapping from these internal systems to the EDI standard 
with which they are sending and/or receiving messages from 
other businesses. Whenever a particular business upgrades 
to a new version of an EDI standard for performing 

3 0 particular business processes, all of its business partners 

are immediately affected and must immediately upgrade their 
translators. A technical advantage provided by system 10 
is that because business applications 16 support "bi- 
directional executability" and "backward compatibility," 

35 a particular client 12 can upgrade the version 18 of a 
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particular business application 16 without negatively 
impacting any other client 12 in system 10. 

Referring to FIGURE 1 to illustrate an example of this 
advantage, client 12a performs a particular business 
5 process using a first version 18 of an appropriate business 

application 16. The first version 18 of business 

application 16 may comprise the lowest level version 18 
maintained by any of clients 12 with which client 12a 
performs the indicated business process. Clients 12b, 12c, 

10 and 12d execute the business process using a second version 

18 of the appropriate business application 16 that is a 
higher version than that maintained by client 12a. 
Furthermore, client 12e performs the business process using 
a third version of business application 16 that is a higher 

15 version 18 than those maintained by any of clients 12a- 12d. 

In this example, if client 12c is a business initiator 
seeking to perform the business process with client 12a, 
client 12c determines that it maintains the higher level 
version 18 of the appropriate business application 16. As 

2 0 a result , client 12c exercises control in executing the 

business process with client 12a according to the 
functionality of the lower level version 18 of the business 
application 16 maintained by client 12a. 

If client 12c is a business initiator seeking to 
25 perform the business process with either of clients 12b or 

12d, client 12c determines that it maintains the same 
version 18 of business application 16 as clients 12b and 
12d. In this situation, the business application 16 of 
business initiator, such as client 12c, generally executes 

3 0 the business process and therefore does not exhibit 

bidirectional executability in this particular situation. 
Furthermore, because the versions 18 of business 
application 16 are the same among clients 12b, 12d, and 
12c, the business application 16 of client 12c does not 
35 exhibit backward compatibility in this particular 

situation. 
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If client 12c is a business initiator seeking to 
perform the business process with client 12e, client 12c 
determines that client 12e maintains the higher level 
version 18 of business application 16. As a result, client 
12e exercises control in executing the business process 
according to the functionality of the lower level version 
18 of the business application 16 maintained by client 12c. 
In each of the above- identified arrangements of partner 
clients 12, the business process is executed in a manner 
supported by the business applications 16 of each client 12 
irregardless of the particular version 18 maintained by any 
given client 12 . 

Assuming now that client 12c upgrades its version 18 
of business application 16 from the second version 18 to a 
fourth version 18 that is a higher version than those 
maintained by clients 12a, 12b, 12d, or 12e. Client 12c 
now maintains the highest level version 18 of business 
application 16 among its partner clients 12. Previously, 
clients 12b and 12d maintained the same version 18 of 
business application 16 as client 12c. However, clients 
12b and 12d now maintain lower versions 18 of business 
application 16 than client 12c. Therefore, system 10 
grants control to client 12c to initiate and execute the 
business process with either of clients 12b or 12d 
according to the functionality of the lower level version 
18 of the business application 16 maintained by clients 12b 
and 12d. Previously, client 12e maintained a higher 
version 18 of business application 16 than client 12c. The 
situation is now reversed. In particular, because client 
12c maintains a fourth version 18 of business application 
16 and client 12e maintains a third version 18 of business 
application 16, client 12c receives control to execute the 
business process according to the lower level version 18 of 
the business application 16 maintained by client 12e. The 
situation between clients 12c and 12a remains unchanged 
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because client 12c still maintains a higher level version 
18 of business application 16 than client 12a. 

None of clients 12a, 12b, 12d, or 12e are impacted by 
the upgrade of business application 16 by client 12c. In 
5 particular, none of clients 12a, 12b, 12d, or 12e need to 

upgrade their respective business applications 16 in order 
to perform a business process with client 12c even though 
client 12c upgraded its version 18 from a second version 18 
to a fourth version 18 of business application 16. This is 

10 because client 12c executes the business process with 

respect to each of clients 12a, 12b, 12d, and 12e, and 
because business application 16 of client 12 exhibits 
backward compatibility that allows it to execute the 
business process according to the functionality of any 

15 lower level versions 18 of the business application 16, 

such as the business applications 16 of clients 12a, 12b, 
12d, and 12e. 

Even if client 12c is not the "business initiator" of 
the business process, the business application 16 of client 

2 0 12c can still execute the business process because it 

supports bidirectional executability . Business 
applications 16 of clients 12b, 12d, and 12e may operate 
differently after the upgrade of business application 16 by 
client 12c because the control of the business process is 
25 no longer with them, but they do not need to be upgraded, 

or modified in any manner, in order to perform the business 
process with client 12c. Because a particular client 12 of 
system 10 may upgrade the version 18 of a particular 
business application 16 without negatively affecting any of 

3 0 its partner clients 12, system 10 is stable and scaleable. 

In particular, system 10 is not in a constant state of 
change so that system 10 is stable with respect to time. 
Furthermore, system 10 can support many clients 12 so that 
it is scaleable in terms of size. Moreover, many clients 
35 12 provide back-end integration of business applications 16 

to systems such as inventory, planning, ERP, and financial 
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systems. The use of business applications 16 allows these 
systems to be preserved because business applications 16 
may also be backward compatible with these systems. In 
this respect the back-end systems are generally shielded 
5 from upgrades to business applications 16 . 

FIGURE 2 illustrates business application 16 in more 
detail. A business application 16 comprises a business 
process module 30 coupled to a version identification 
module 32 and a status message module 34. Business process 

10 module 30 includes software code, parameters, protocols, 

and other instructions and data structures that execute to 
perform the business process associated with the particular 
business application 16. For example, business process 
module 30 generates and/or communicates business messages 

15 35 to perform the business process. Business messages 35 

comprise request messages, response messages, or any other 
type of communication between clients 12 to facilitate the 
execution of a business process. Business messages 3 5 may 
be generated in a manner supported by lower level versions 

20 18 of the business application 16. In this respect, the 

features and functions of business process module 3 0 may be 
enhanced, increased, or otherwise upgraded with each 
version 18 of a particular business application 16. The 
business process module 3 0 supports the backward 

25 compatibility and bidirectional executability described 

above with reference to the business application 16. 

Version identification module 32 comprises software 
code, parameters, protocols, and other instructions and 
data structures that execute to determine which client 12 

3 0 among a group of partner clients 12 maintains a higher 

level version 18 of a particular business application 16 
used to perform a particular business process. In one 
embodiment, version identification module 32 may generate 
a version identification request 3 6 for communication to 

35 one or more partner clients 12. A version identification 

request 3 6 comprises a request for information identifying 
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the version 18 of a particular business application 16, 
Module 32 generates the version identification request 3 6 
according to a version identification protocol that 
configures the request 3 6 in a format supported by any 
5 version 18 of the appropriate business application 16. In 

this respect, version identification modules 32 remain 
unchanged among varying degrees of versions 18 for a 
particular business application 16. 

Status message module 34 comprises software codes, 

10 parameters, protocols and other instructions and data 

structures that execute to generate a status message 3 8 for 
communication to one or more partner clients 12. Status 
messages 38 comprise information indicating the presence of 
a business message 35 associated with the business process. 

15 Status message module 34 generates the status message 3 8 

according to a status message protocol that configures 
status message 38 in a format supported by any version 18 
of the appropriate business application 16. In this 
respect, status message modules 34 remain unchanged among 

2 0 varying degrees of versions 18 for the appropriate business 

application 16. 

FIGURES 3A and 3B illustrate exemplary communications 
between different clients 12 of system 10 to perform a 
business process. Although the description of FIGURES 3A 
25 and 3B is detailed with respect to a buyer client 12 and a 

seller client 12 performing an order purchasing business 
process, it should be understood that the features and 
functions of system 10 support any suitable business 
process among any number and combination of clients 12. 

3 0 The business initiator of the business process , such as 

buyer client 12, communicates a version identification 
request 36 to the seller client 12 at 40. Version 
identification module 32 of the appropriate business 
application 16 for buyer client 12 generates version 
3 5 identification request 3 6 according to the version 

identification protocol supported by all versions 18 of the 
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business application 16, Seller client 12 communicates a 
version identifier at 42 in response to the version 
identification request 36 to indicate the version 18 of the 
business application 16 maintained by seller client 12 to 
5 perform the order purchasing business process. 

Upon determining the version 18 of the business 
application 16 maintained by seller client 12 based upon 
the communication by seller client 12 at 42 or, in one 
embodiment, according to version identifiers stored 

10 locally, buyer client 12 determines one of buyer client 12 

and seller client 12 to initiate the business process. 
Business process module 3 0 of the appropriate business 
application 16 for buyer client 12 selects buyer client 12 
to execute the business process if the version 18 of 

15 business application 16 for seller client 12 is not higher 

than the version 18 of business application 16 for buyer 
client 12 . FIGURE 3A illustrates an example of buyer 
client 12 maintaining a higher level version 18 of business 
application 16 than seller client 12 . FIGURE 3B 

20 illustrates an example of seller client 12 maintaining a 

higher level version 18 of business application 16 than 
buyer client 12 . 

Referring back to FIGURE 3A, buyer client 12 
communicates to seller client 12 a business message 35, 

25 such as a purchase order associated with the order 

purchasing business process, at 44, Business process 
module 3 0 of business application 16 for buyer client 12 
generates the business message 3 5 according to the version 
18 of business application 16 maintained by seller client 

30 12. In this regard, business application 16 for buyer 

client 12 exhibits backward compatibility with business 
application 16 of seller client 12 to perform the business 
process . 

Seller client 12 communicates a status message 38 to 
35 buyer client 12 at 46 to indicate the presence of a 

business message 35 associated with the business process. 
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The status message module 34 of the appropriate business 
application 16 maintained by seller client 12 generates the 
status message 38 according to a status message protocol 
that is supported by all versions 18 of the business 
5 application 16. The status message 38 essentially 

indicates to buyer client 12 that a business message 3 5 is 
pending for it at seller client 12. A technical advantage 
provided by the status message 3 8 is that it eliminates the 
need for buyer client 12 to repeatedly poll seller client 

10 12 in order to detect the availability of pending messages 

35. The status message 38 communicated by seller client 12 
to buyer client 12 at 46 is associated with an identifier 
for the business process for which the business message is 
pending. Therefore, in a order purchasing business process 

15 performed by client 12, the status message 38 may indicate 

the presence of a business message 35, such as an 
acknowledgment to the purchase order, associated with an 
identifier of the order purchasing business process. 

In response to receiving a status message 3 8 at 46, 

2 0 buyer client 12 retrieves the appropriate business message 

35 from seller client 12 at 48. Business process module 30 
of the application 16 maintained by buyer client 12 
generally retrieves a business message 35 at 48 using 
commands, data structures, message formats, and other 

25 functionality according to the lower level version 18 of 

business application 16 maintained by seller client 12 . 
Further communications may be made by buyer client 12 
and/or seller client 12 to complete the appropriate 
business process in a manner similar to the communications 

30 described above with reference to FIGURE 3A. 

FIGURE 3B illustrates another example of the 
communications made by buyer client 12 and seller client 12 
while performing the order purchasing business process 
described above with reference to FIGURE 3A. More 

35 specifically, FIGURE 3B illustrates communications made 

between buyer client 12 and seller client 12 where buyer 
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client 12 determines that seller client 12 maintains a 
higher level version 18 of the appropriate business 
application 16 based upon the version identification 
request 36 communicated at 40 and the version identifier 
5 received by buyer client 12 at 42. Therefore, seller 

client 12 maintains control over the execution of the 
business process. 

The version identification request 3 6 communicated by 
buyer client 12 at 40 indicates to seller client 12 that 

10 buyer client 12 has generated a business message associated 

with the order purchasing business process. Seller client 
12 retrieves the business message 3 5 from buyer client 12 
at 60 using the commands, data structures, message formats 
and functionality associated with the lower level version 

15 18 of the business application 16 maintained by buyer 

client 12. In this respect, the business application 16 of 
seller client 12 exhibits backward compatibility to 
communicate seamlessly with lower level versions 18 of 
business application 16. The business message 35 retrieved 

2 0 by seller client 12 performing the order purchasing 

business process may comprise a purchase order generated by 
buyer client 12 . 

Seller client 12 generates and communicates a business 
message 35, such as an acknowledgment to the purchase 
25 order, at 62 according to the lower level version 18 of 

business application 16 maintained by buyer client 12. 
Buyer client 12 communicates a status message 3 8 to seller 
client 12 at 64 to indicate the presence of a business 
message 35 associated with the business process, such as a 

3 0 response to the seller client 12 acknowledgment. Status 

message module 34 of business application 16 for buyer 
client 12 generates the status message 3 8 according to the 
status message protocol supported by all versions 18 of 
business application 16. In response to receiving the 
35 status message 38 at 64, seller client 12 retrieves the 

business message 35 generated by buyer client 12 at 66 
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using functionality associated with the lower level version 
18 of business application 16 maintained by buyer client 
12 . 

A technical advantage associated with system 10 is 
5 that although buyer client 12 is the business initiator in 

the order purchasing business process illustrated in FIGURE 
3B, the seller client 12 exhibits bidirectional 
executability to control the execution of the business 
process, and further exhibits backward compatibility to 

10 perform the business process according to the functionality 

of the lower level version 18 of business application 16 
maintained by buyer client 12 . 

FIGURE 4 is a flowchart of an exemplary method for 
performing a business process according to the present 

15 invention. The method begins at steps 70 where a first 

client 12, such as a business initiator, performs an 
inquiry of partner clients 12 to determine the versions 18 
of the business applications 16 maintained by the partner 
clients 12 for the particular business process to be 

2 0 executed. In particular, the first client 12 communicates 

to each of its partner clients 12 a version identification 
request 36 associated with the particular business process, 
at step 72. Although the first client 12 may perform the 
business process with any number and combination of partner 
25 clients 12, the following description of FIGURE 4 will be 

detailed with respect to a first client 12 and a second 
client 12 . The first client 12 receives a version 
identifier from the second client 12 at step 74. The 
version identifier indicates the version 18 of the business 

3 0 application 16 maintained by the second client 12 to 

perform the identified business process. 

The first client 12 determines whether it maintains 
the higher level version 18 of the appropriate business 
application 16 at step 80. If so, execution proceeds to 
35 steps 82 where the first client 12 executes the business 

process according to the functionality of the lower level 
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version 18 of the business application 16 maintained by the 
second client 12. If the first client 12 does not maintain 
the higher level version 18 of the business application 16 
as determined at step 80, execution proceeds to steps 84 
5 where the second client 12 executes the business process 

according to the functionality of the lower level version 
18 of the business application 16 maintained by the first 
client 12 . 

Referring to steps 82, the first client 12 

10 communicates to the second client 12 a business message 35 

at step 90. The business application 16 of the first 
client 12 exhibits backward compatibility to generate the 
business message 35 according to the functionality of the 
lower level version 18 of the business application 16 

15 maintained by the second client 12. The first client 12 

receives a status message 3 8 at step 92 indicating the 
presence of a business message 3 5 generated by the second 
client 12 in response to the business message 35 
communicated by the first client 12 at step 90. The status 

20 message 38 received at step 92 is generated according to a 

status message protocol supported by all versions 18 of the 
appropriate business application 16. The first client 12 
retrieves the business message 3 5 generated by the second 
client 12, at step 94, using commands, data structures, 

25 message formats, and functionality associated with the 

lower level version 18 of business application 16 
maintained by the second client 12. The first client 12 
determines whether to communicate another business message 
35 at step 96. If so, execution returns to step 90. If 

3 0 not, execution terminates at step 110. 

Referring to steps 84, the second client 12 retrieves 
a business message 35 from the first client 12 at step 100 
in response to the inquiry performed by the first client 12 
at steps 70. Second client 12 retrieves the business 

3 5 message 3 5 from the first client 12 using commands, data 

structures, message formats, and functionality associated 
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with the lower level version 18 of the business application 
16 maintained by the first client 12. In this respect, the 
business application 16 of the second client 12 exhibits 
both bidirectional executability and backward 
5 compatibility. The second client 12 communicates a 

business message 35 to the first client 12 at step 102 and 
receives a status message at step 104 indicating the 
presence of a business message 35 generated by the first 
client 12 according to the status message protocol 

10 supported by all versions 18 of the business application 

16. The second client 12 retrieves the business message 35 
generated by the first client 12 at step 106 according to 
the functionality associated with the lower level version 
18 of business application 16 maintained by the first 

15 client 12. The second client 12 determines whether to 

communicate another business message 35 at step 108. If 
so, execution returns to step 102. If not, execution 
terminates at step 110, 

Although the present invention has been described in 

2 0 several embodiments, a myriad of changes, variations, 

alterations, transformations, and modifications may be 
suggested to one skilled in the art, and it is intended 
that the present invention encompass such changes, 
variations, alterations, transformations, and modifications 

25 as fall within the spirit and scope of the appended claims. 
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WHAT IS CLAIMED IS: 

1. A system for performing a business process, 
comprising : 

a first version of a business application that is 
identified using a first version identifier and executed by 
a first client to perform a particular business process; 
and 

a second version of the business application that is 
identified using a second version identifier and executed 
by a second client to perform the business process, wherein 
the second client is coupled to the first client using a 
communication link and the second version of the business 
application is operable to determine a selected one of the 
first version of the business application and the second 
version of the business application to initiate the 
business process based upon the first version identifier 
and the second version identifier. 

2, The system of Claim 1, wherein: 

the second version of the business application 
comprises a version identification module operable to 
generate a version identification request for communication 
to the first client, wherein the version identification 
request is associated with the particular business process 
and generated according to a version identification 
protocol supported by the first version of the business 
application and the second version of the business 
application; and 

the first version of the business application 
comprises a version identification module operable to 
initiate communicating the first version identifier to the 
second version of the business application in response to 
the version identification request. 
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3. The system of Claim 1, wherein the second version 
of the business application is operable to control the 
business process if the first version of the business 
application is not higher than the second version of the 

5 business application. 

4. The system of Claim 3, wherein the second version 
of the business application further comprises a business 
process module operable to: 

10 generate a first business message associated with 

the business process for communication to the first 
client, the first business message generated according 
to the first version of the business application; and 
initiate retrieving from the first client a 

15 second business message generated according to the 

first version of the business application. 

5. The system of Claim 3, wherein the first version 
of the business application further comprises a status 

2 0 message module operable to generate a status message for 

communication to the second client to indicate the presence 
of a business message associated with the business process, 
the status message generated according to a status message 
protocol supported by the first version of the business 
25 application and the second version of the business 

application. 

6. The system of Claim 1, wherein the first version 
of the business application is operable to control the 

3 0 business process if the first version of the business 

application is higher than the second version of the 
business application . 
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7. The system of Claim 6, wherein the first version 
of the business application further comprises a business 
process module operable to: 

initiate retrieving from the second client a 
first business message associated with the business 
process, the first business message generated 
according to the second version of the business 
application; and 

generate a second business message associated 
with the business process for communication to the 
second client, the second business message generated 
according to the second version of the business 
application. 

8. The system of Claim 6, wherein the second version 
of the business application further comprises a status 
message module operable to generate a status message for 
communication to the first client to indicate the presence 
of a business message associated with the business process, 
the status message generated according to a status message 
protocol supported by the second version of the business 
application and the first version of the business 
application. 
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9. A method for performing a business process, 
comprising: 

determining a first version identifier associated with 
a first version of a business application used by a first 
client to perform a business process; 

determining a second version identifier associated 
with a second version of the business application used by 
a second client to perform the business process; and 

determining a selected one of the first version of the 
business application and the second version of the business 
application to initiate the business process based upon the 
first version identifier and the second version identifier. 

10. The method of Claim 9, further comprising: 
generating a version identification request for 

communication to the first client; and 

receiving the first version identifier in response to 
the version identification request. 

11. The method of Claim 10, wherein the step of 
generating comprises generating the version identification 
request according to a version identification protocol that 
is supported by the first version of the business 
application and the second version of the business 
application. 

12. The method of Claim 9, further comprising 
controlling the business process by the second version of 
the business application if the first version of the 
business application is not higher than the second version 
of the business application. 
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13. The method of Claim 12, further comprising: 
generating a first business message associated with 

the business process for communication to the first client, 
the first business message generated according to the first 
version of the business application; and 

retrieving a second business message generated by the 
first client according to the first version of the business 
application. 

14. The method of Claim 12, further comprising: 
receiving a status message generated by the first 

client according to a status message protocol that is 
supported by the first version of the business application 
and the second version of the business application, the 
status message indicating the presence of a business 
message associated with the business process; and 

retrieving the business message from the first client 
in response to the status message. 

15. The method of Claim 9, further comprising 
controlling the business process by the first version of 
the business application if the first version of the 
business application is higher than the second version of 
the business application. 

16. The method of Claim 15, further comprising: 
retrieving from the second client a first business 

message associated with the business process, the first 
business message generated according to the second version 
of the business application; and 

communicating to the second client a second business 
message generated according to the second version of the 
business application . 
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17. The method of Claim 15, further comprising: 
receiving a status message generated by the second 

client according to a status message protocol supported by 
the first version of the business application and the 
5 second version of the business application, the status 

message indicating the presence of a business message 
associated with the business process; and 

retrieving the business message from the second client 
in response to the status message. 

10 

18. The method of Claim 9, further comprising: 
performing the business process according to the first 

version of the business application if the first version of 
the business application is not higher than the second 
15 version of the business application; and 

performing the business process according to the 
second version of the business application if the first 
version of the business application is higher than the 
second version of the business application. 
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19. A business application for performing a business 
process, the application encoded on a computer- readable 
medium and operable to execute the following steps: 

determining a first version identifier associated with 
a first version of the business application used by a first 
client to perform a business process; 

determining a second version identifier associated 
with a second version of the business application used by 
a second client to perform the business process; and 

determining a selected one of the first client and the 
second client to initiate the business process based upon 
the first version identifier and the second version 
identifier. 

20. The business application of Claim 19, further 
comprising : 

generating a version identification request for 
communication to the first client; and 

receiving the first version identifier in response to 
the version identification request. 

21. The business application of Claim 20, wherein the 
step of generating comprises generating the version 
identification request according to a version 
identification protocol that is supported by the first 
version of the business application and the second version 
of the business application. 

22. The business application of Claim 19, further 
comprising controlling the business process by the second 
version of the business application if the first version of 
the business application is not higher than the second 
version of the business application. 
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23. The business application of Claim 22, further 
comprising : 

generating a first business message associated with 
the business process for communication to the first client, 
the first business message generated according to the first 
version of the business application; and 

retrieving a second business message generated by the 
first client according to the first version of the business 
application. 

24. The business application of Claim 22, further 
comprising: 

receiving a status message generated by the first 
client according to a status message protocol that is 
supported by the first version of the business application 
and the second version of the business application, the 
status message indicating the presence of a business 
message associated with the business process; and 

retrieving the business message from the first client 
in response to the status message . 

25. The business application of Claim 19 further 
comprising controlling the business process by the first 
version of the business application if the first version of 
the business application is higher than the second version 
of the business application. 



ATTORNEY'S DOCKET: 
020431. 0560 



31 



PATENT APPLICATION 



26. The business application of Claim 25, further 
comprising: 

retrieving from the second client a first business 
message associated with the business process, the first 
business message generated according to the second version 
of the business application; and 

communicating to the second client a second business 
message generated according to the second version of the 
business application. 

27. The business application of Claim 25, further 
comprising: 

receiving a status message generated by the second 
client according to a status message protocol supported by 
the first version of the business application and the 
second version of the business application, the status 
message indicating the presence of a business message 
associated with the business process; and 

retrieving the business message from the second client 
in response to the status message. 

28. The business application of Claim 19, further 
comprising: 

performing the business process according to the first 
version of the business application if the first version of 
the business application is not higher than the second 
version of the business application; and 

performing the business process according to the 
second version of the business application if the first 
version of the business application is higher than the 
second version of the business application. 
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SYSTEM AND METHOD FOR PERFORMING A BUSINESS PROCESS 
IN A MULTI -ENTERPRISE, COLLABORATING NETWORK 



ABSTRACT OF THE DISCLOSURE 

A system for performing a business process includes a 
first version of a business application executed by a first 
client to perform a particular business process and a 
second version of the business application executed by a 
second client to perform the business process, wherein the 
first client is coupled to the second client using a 
communication link. The first version of the business 
application is identified using a first version identifier 
and the second version of the business application is 
identified using a second version identifier. One of the 
first version of the business application and the second 
version of the business application is selected to initiate 
the business process based upon the first version 
identifier and the second version identifier. 




in 





r 



< 



.7^ 



I 



1 — ^ I 




J. 









^ 








J 



Qdviei^ Bus'a^ Ai^fsa.^ f 



I 

L _ _ _ 



ATTORNEY DOCKET NO. 
020431.0560 



PATENT 



1 



DECLARATION AND POWER OF ATTORNEY 
As a below named inventor^ I declare that: 

My residence^ post office address and citizenship are as 
stated below next to my name; that I believe I am the original;, 
first and sole inventor (if only one name is listed below) or an 
original;, first and joint inventor (if plural names are listed 
below) of the subject matter which is claimed and for which a 
patent is sought on the invention or design entitled SYSTEM AND 
METHOD FOR PERFORMING A BUSINESS PROCESS IN A MULTI-ENTERPRISE, 
COLLABORATING NETWORK the specification of which is attached 
hereto; that I have reviewed and understand the contents of the 
above-identified specification, including the claims, as amended 
by any amendment referred to above; and that I acknowledge the 
duty to disclose to the U.S. Patent and Trademark Office all 
information known to me to be material to patentability as 
defined in 37 C.F.R. § 1.56. 

I hereby claim foreign priority benefits under 35 UoS.C. 
§ 119 of any foreign application { s ) for patent or inventor's 
certificate listed below and have also identified below any 
foreign application ( s ) for patent or inventor's certificate 
having a filing date before that of the application on which 
priority is claimed: 

Priority 
Date Claimed 
Number Country Filed (Yes) (No) 

js^ONE 

I hereby claim the benefit under 35 U.S.C. § 120 of any 
United States application ( s ) listed below and, insofar as the 
subject matter of each of the claims of this application is not 
disclosed in the prior United States application ( s ) in the manner 
provided by the first paragraph of 35 U.S.C. § 112, I acknowledge 



ATTORNEY DOCKET NO. 
020431.0560 



PATENT 



2 

the duty to disclose to the U.S. Patent and Trademark Office all 
information known to me to be material to patentability as 
defined in 37 C.F.R. § 1.56 which became available between the 
filing date of the prior application ( s ) and the national or PCT 
international filing date of this application: 

Application 

Serial Number Date Filed Status 



jqONE 

I hereby appoint: 



Jerry W. Mills 


Reg . 


No. 


23, 005 


Robert M. Chiaviello, Jr. 


Reg . 


No. 


32, 461 


Samir A. Bhavsar 


Reg. 


No. 


41, 617 


James L. Baudino 


Reg. 


No. 


43, 486 


Thomas R. Felger 


Reg . 


No. 


28 , 842 


Charles S. Fish 


Reg . 


No. 


35, 870 


Robert W. Holland 


Reg. 


No. 


40, 020 


Wei Wei Jeang 


Reg. 


No. 


33,305 


Jay B. Johnson 


Reg. 


No. 


38, 193 


Christopher W. Kennerly 


Reg. 


No. 


40, 675 


Tara D. Knapp 


Reg. 


No. 


43,723 


Douglas M. Kubehl 


Reg. 


No. 


41, 915 


Ann C. Livingston 


Reg. 


No. 


32, 479 


Kevin J. Meek 


Reg. 


No. 


33, 738 


Harold E. Meier 


Reg. 


No. 


22, 428 


Randall W. Mishler 


Reg. 


No. 


42,006 


Scott T. Morris 


Reg . 


No. 


43,818 


Barton E. Showalter 


Reg. 


No. 


38, 302 


T. Murray Smith 


Reg . 


No. 


30,222 


Terry J. Stalford 


Reg . 


No. 


39, 522 


David G. Wille 


Reg . 


No. 


38,363 


Bradley P. Williams 


Reg. 


No. 


40, 227 


Rodger L. Tate 


Reg . 


No. 


27,399 


Scott F. Partridge 


Reg. 


No. 


28,142 


James B. Arpin 


Reg. 


No. 


33, 470 


James Remenick 


Reg. 


No. 


36, 902 


Roger J. Fulghum 


Reg. 


No. 


39, 678 


Thomas R. Nesbitt, Jr. 


Reg. 


No. 


22, 075 


James J. Maune 


Reg. 


No. 


26, 946 



all of the firm of Baker & Botts, L.L.P., my attorneys with full 
power of substitution and revocation, to prosecute this 
application and to transact all business in the United States 



ATTORNEY DOCKET NG . 
020431 . 0560 



PATENT 



3 



Patent and Trademark Office connected therewith, and to file and 
prosecute any international patent applications filed thereon 
before any international authorities under the Patent Cooperation 
Treaty. 

Send Correspondence To : Direct Telephone Calls To : 

Baker & BottS;. L.L.P. Christopher W. Kennerly 

2001 Ross Avenue at (214) 953-6812 

Dallas, Texas 75201-2980 Attorney Docket No. 020431.0560 



1 declare that all statements made herein of my own knowledge are 
true and that all statements made on information and belief are 
believed to be true; and further that these statements were made 
with the knowledge that willful false statements and the like so 
made are punishable by fine or imprisonment, or both, under 
Section 1001 of Title 18 of the United States Code, and that such 
willful false statements may jeopardize the validity of the 
application or any patent issuing thereon. 



Full name of first inventor Ran jit N. Notani 

/ • A/ ' Ajt^fa^ 



Inventor ^ s signature 
Date 



Residence (City, County, State) Irving, Dallas County, 

Texas 

Citizenship India 

Post Office Address 1218 Hidden Ridge #2070 

Irving, Texas 75038 



DALOl : 479758 . 1 



